草庐IT

java - 处理 HardDeadlineExceededError 的任务策略

全部标签

ruby - 如何将数组作为参数传递给 Rake 任务?

我正在编写一个Rake任务,我想传递一个数组作为参数之一。这是我目前的情况。task:change_statuses,:ids,:current_status,:new_statusdo|task,args|puts"argswere#{args.inspect}"end我试过以这些方式运行任务:#Firstargumentasarrayrake"change_statuses[[1,2,3],active,inactive]"#Firstargumentasstringrake"utility:change_account_statuses['1,2,3',foo,bar]"我的预期

ruby-on-rails - 获取 fields_for 和 accepts_nested_attributes_for 以处理 belongs_to 关系

我似乎无法使用Rails2.3的新accepts_nested_attributes_for工具在RailsView中为belongs_to关系生成嵌套表单。我确实检查了许多可用的资源,看起来我的代码应该可以工作,但是fields_for对我来说是爆炸性的,我怀疑它与如何做有关我配置了嵌套模型。我遇到的错误是一个常见的错误,可能有多种原因:'@account[owner]'isnotallowedasaninstancevariablename下面是涉及的两个模型:classAccount'User',:foreign_key=>'owner_id'accepts_nested_att

ruby - 你有什么策略来保持低内存使用率?

Ruby真的很耗费内存——但也值得每一点。您如何保持低内存使用率?您是避免使用大字符串并改用较小的数组/散列,还是让垃圾收集器完成这项工作对您来说没有问题?编辑:我找到了一篇关于这个主题的好文章here-古老但仍然有趣。 最佳答案 我发现Phusion的RubyEnterpriseEdition(主线Ruby的一个分支,垃圾收集功能得到了很大改进)在内存使用方面产生了巨大的变化......此外,它们还非常容易安装(和删除),如果您发现需要)。您可以在theirwebsite上找到更多信息并下载。.

ruby - 如何将多个参数传递给 rake 任务

我想传递多个参数,但我不知道数字。比如型号名称。如何将这些参数传递给rake任务以及如何在rake任务中访问这些参数。喜欢,$raketest_rake_task[par1,par2,par3] 最佳答案 您可以使用args.extras遍历所有参数,而无需明确说明您有多少个参数。例子:desc"Bringiton,parameters!"task:infinite_parametersdo|task,args|putsargs.extras.countargs.extras.eachdo|params|putsparamsende

ruby-on-rails - 如何使用 YARD 记录 Rake 任务?

我想在我们的Rails应用程序中包含有关Rake任务的信息。我们使用YARD用于文档,目前像lib/tasks/development.rake这样的页面默认显示为未格式化的文本。我可以使用#@markupruby​​fromtheYARDdocumentation将它们呈现为Ruby源代码.但是,这只会呈现任何内联注释,即使它们包含像#@!methodfoo这样的YARD指令。这意味着theYARDdocumentationontaggingDSLs似乎不适用。我错过了什么吗?如何让YARD识别.rake文件中的代码与文档?注意我会很高兴有一个忽略实际代码并只生成文档副本的解决方案,

ruby - 如何将 Rake 任务添加到默认 Rake 任务?

Rspec和Cucumber以某种方式将其纳入我的默认rake任务(这很好,因为我希望它们在那里)。但是我已经尝试在默认任务中添加额外的任务,但没有任何效果。将任务添加到默认rake任务的正确方法是什么? 最佳答案 通常你的Rakefile会有这样的东西:task:default=>[:spec]您只需要将更多任务添加到此列表中即可。 关于ruby-如何将Rake任务添加到默认Rake任务?,我们在StackOverflow上找到一个类似的问题: https:

ruby - 让 gem 的 rake 任务随处可用?

因此,我正在编写一个小gem,其中有一个“/tasks”目录,其中包含一些特定的rake任务。如何在需要gem的任何地方自动执行这些任务?例如,我希望在安装gem后,我可以在我的rails根目录中运行“rakemygemrake:task”。 最佳答案 对于Rails3应用程序,您可能需要考虑为您的gem制作Railtie。您可以这样做:lib/your_gem/railtie.rbrequire'your_gem'require'rails'moduleYourGemclassRailtielib/your_gem.rbmodul

ruby-on-rails - Rails App 在后台运行长时间任务的最佳实践?

我有一个Rails应用程序,不幸的是,在向Controller发出请求后,它必须进行一些需要一段时间的处理。在Rails中为长时间运行的任务或请求提供反馈或进度的最佳实践是什么?这些Controller方法通常持续60秒以上。我不关心客户端...我计划每隔一秒左右发出一个Ajax请求并显示一个进度指示器。我只是不确定Rails的最佳实践,我要创建一个额外的Controller吗?我能做点什么聪明的事吗?我希望答案集中在仅使用Rails的服务器端。预先感谢您的帮助。编辑:如果重要的话,http请求是针对PDF的。然后我让Rails与Ruport一起生成这些PDF。问题是,这些PDF非常大

ruby-on-rails - 如何使用 Rails 4 同时处理请求?

我正在尝试在Rails4中同时处理多个请求,我在Rails3中使用config.threadsafe!和Puma可以很轻松地做到这一点。假设我有这个ControllerclassConcurrentController我过去可以使用puma-t2:16-p3000(对于最少2个线程)启动puma,然后点击index然后show并且仍然可以正确呈现show。在Rails4中,如果我尝试做同样的事情,Puma现在会锁定index请求并且show永远不会被渲染。当我为服务器按下Ctrl-C时,Puma给我这个错误:Rackapperror:#为了让Rails4并发工作,我在这里缺少什么?co

ruby - 处理在 Ruby 线程中引发的异常

我正在寻找异常处理经典问题的解决方案。考虑以下代码:deffoo(n)puts"for#{n}"sleepnraise"after#{n}"endbeginthreads=[][5,15,20,3].eachdo|i|threadseputs"EXCEPTION:#{e.inspect}"puts"MESSAGE:#{e.message}"end此代码在5秒后捕获异常。但是如果我将数组更改为[15,5,20,3],上面的代码会在15秒后捕获异常。简而言之,它总是捕获第一个线程中引发的异常。任何想法,为什么会这样。为什么每次3秒后不捕获异常?我如何捕获任何线程引发的第一个异常?